package cn.nbt.busManage.repository;

import cn.nbt.busManage.model.entity.Route;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Optional;

/**
 * {@code @Author} lyq
 * {@code @Date} 6/13/2024 7:17 PM
 */

@Repository
public interface RouteRepository extends JpaRepository<Route,Integer> {

    /**
     * 根据线路名称查询线路
     * @param routeName 线路名称
     * @return 线路信息
     */
    @Query("select r from Route r where r.routeName=:routeName")
    Optional<Route> findByRouteName(@Param("routeName") String routeName);

    /**
     * 更新线路信息
     * @param id 线路id
     * @param routeName 线路名称
     * @param startPointId 起始站点id
     * @param endPointId 终点站点id
     * @param points 站点列表
     * @param times 站点时间
     */
    @Modifying
    @Query("update Route r set r.routeName=:routeName, r.startPointId=:startPointId, r.endPointId=:endPointId, r.points=:points, r.times=:times where r.id=:id")
    void updateRoute(@Param("id") Integer id, @Param("routeName") String routeName, @Param("startPointId") Integer startPointId, @Param("endPointId") Integer endPointId, @Param("points") String points, @Param("times") String times);


}
